home *** CD-ROM | disk | FTP | other *** search
/ Aminet 48 / Aminet 48 (2002)(GTI - Schatztruhe)[!][Apr 2002].iso / Aminet / text / edit / vim60rt.lha / Vim / vim60 / doc / usr_40.txt < prev    next >
Encoding:
Text File  |  2001-09-26  |  22.5 KB  |  653 lines

  1. *usr_40.txt*    For Vim version 6.0.  Last change: 2001 Sep 03
  2.  
  3.              VIM USER MANUAL - by Bram Moolenaar
  4.  
  5.                   Make new commands
  6.  
  7.  
  8. Vim is an extensible editor.  You can take a sequence of commands you use
  9. often and turn it into a new command.  Or redefine an existing command.
  10. Autocommands make it possible to execute commands automatically.
  11.  
  12. |40.1|    Key mapping
  13. |40.2|    Defining command-line commands
  14. |40.3|    Autocommands
  15.  
  16.      Next chapter: |usr_41.txt|  Write a Vim script
  17.  Previous chapter: |usr_31.txt|  Exploiting the GUI
  18. Table of contents: |usr_toc.txt|
  19.  
  20. ==============================================================================
  21. *40.1*    Key mapping
  22.  
  23. A simple mapping was explained in section |05.3|.  The principle is that one
  24. sequence of key strokes is translated into another sequence of key strokes.
  25. This is a simple, yet powerful mechanism.
  26.    The simplest form is that one key is mapped to a sequence of keys.  Since
  27. the function keys, except <F1>, have no predefined meaning in Vim, these are a
  28. good choice to map.  Example: >
  29.  
  30.     :map <F2> GoDate: <Esc>:read !date<CR>kJ
  31.  
  32. This shows how three modes are used.  After going to the last line with "G",
  33. the "o" command opens a new line and starts Insert mode.  The text "Date: " is
  34. inserted and <Esc> takes you out of insert mode.
  35.    Notice the use of special keys inside <>.  This is called angle bracket
  36. notation.  You type these as separate characters, not by pressing the key
  37. itself.  This makes the mappings better readable and you can copy and paste
  38. the text without problems.
  39.    The ":" character takes Vim to the command line.  The ":read !date" command
  40. reads the output from the "date" command and appends it below the current
  41. line.  The <CR> is required to execute the ":read" command.
  42.    At this point of execution the text looks like this:
  43.  
  44.     Date:  ~
  45.     Fri Jun 15 12:54:34 CEST 2001 ~
  46.  
  47. Now "kJ" moves the cursor up and joins the lines together.
  48.    To decide which key or keys you use for mapping, see |map-which-keys|.
  49.  
  50.  
  51. MAPPING AND MODES
  52.  
  53. The ":map" command defines remapping for keys in Normal mode.  You can also
  54. define mappings for other modes.  For example, ":imap" applies to Insert mode.
  55. You can use it to insert a date below the cursor: >
  56.  
  57.     :imap <F2> <CR>Date: <Esc>:read !date<CR>kJ
  58.  
  59. It looks a lot like the mapping for <F2> in Normal mode, only the start is
  60. different.  The <F2> mapping for Normal mode is still there.  Thus you can map
  61. the same key differently for each mode.
  62.    Notice that, although this mapping starts in Insert mode, it ends in Normal
  63. mode.  If you want it to continue in Insert mode, append a "a" to the mapping.
  64.  
  65. Here is an overview of map commands and in which mode they work:
  66.  
  67.     :map        Normal, Visual and Operator-pending
  68.     :vmap        Visual
  69.     :nmap        Normal
  70.     :omap        Operator-pending
  71.     :map!        Insert and Command-line
  72.     :imap        Insert
  73.     :cmap        Command-line
  74.  
  75. Operator-pending mode is when you typed an operator character, such as "d" or
  76. "y", and you are expected to type the motion command or a text object.  Thus
  77. when you type "dw", the "w" is entered in operator-pending mode.
  78.  
  79. Suppose that you want to define <F7> so that the command d<F7> deletes a C
  80. program block (text enclosed in curly braces, {}).  Similarly y<F7> would yank
  81. the program block into the unnamed register.  Therefore, what you need to do
  82. is to define <F7> to select the current program block.  You can do this with
  83. the following command: >
  84.  
  85.     :omap <F7> a{
  86.  
  87. This causes <F7> to perform a select block "a{" in operator-pending mode, just
  88. like you typed it.  This mapping is useful if typing a { on your keyboard is a
  89. bit difficult.
  90.  
  91.  
  92. LISTING MAPPINGS
  93.  
  94. To see the currently defined mappings, use ":map" without arguments.  Or one
  95. of the variants that include the mode in which they work.  The output could
  96. look like this:
  97.  
  98.        _g         :call MyGrep(1)<CR> ~
  99.     v  <F2>         :s/^/> /<CR>:noh<CR>`` ~
  100.     n  <F2>         :.,$s/^/> /<CR>:noh<CR>`` ~
  101.        <xHome>     <Home>
  102.        <xEnd>     <End>
  103.  
  104.  
  105. The first column of the list shows in which mode the mapping is effective.
  106. This is "n" for Normal mode, "i" for Insert mode, etc.  A blank is used for a
  107. mapping defined with ":map", thus effective in both Normal and Visual mode.
  108.    One useful purpose of listing the mapping is to check if special keys in <>
  109. form have been recognized (this only works when color is supported).  For
  110. example, when <Esc> is displayed in color, it stands for the escape character.
  111. When it has the same color as the other text, it is five characters.
  112.  
  113.  
  114. REMAPPING
  115.  
  116. The result of a mapping is inspected for other mappings in it.  For example,
  117. the mappings for <F2> above could be shortened to: >
  118.  
  119.     :map <F2> G<F3>
  120.     :imap <F2> <Esc><F3>
  121.     :map <F3>  oDate: <Esc>:read !date<CR>kJ
  122.  
  123. For Normal mode <F2> is mapped to go to the last line, and then behave like
  124. <F3> was pressed.  In Insert mode <F2> stops Insert mode with <Esc> and then
  125. also uses <F3>.  Then <F3> is mapped to do the actual work.
  126.  
  127. Suppose you hardly ever use Ex mode, and want to use the "Q" command to format
  128. text (this was so in old versions of Vim).  This mapping will do it: >
  129.  
  130.     :map Q gq
  131.  
  132. But, in rare cases you need to use Ex mode anyway.  Let's map "gQ" to Q, so
  133. that you can still go to Ex mode: >
  134.  
  135.     :map gQ Q
  136.  
  137. What happens now is that when you type "gQ" it is mapped to "Q".  So far so
  138. good.  But then "Q" is mapped to "gq", thus typing "gQ" results in "gq", and
  139. you don't get to Ex mode at all.
  140.    To avoid keys to be mapped again, use the ":noremap" command: >
  141.  
  142.     :noremap gQ Q
  143.  
  144. Now Vim knows that the "Q" is not to be inspected for mappings that apply to
  145. it.  There is a similar command for every mode:
  146.  
  147.     :noremap    Normal, Visual and Operator-pending
  148.     :vnoremap    Visual
  149.     :nnoremap    Normal
  150.     :onoremap    Operator-pending
  151.     :noremap!    Insert and Command-line
  152.     :inoremap    Insert
  153.     :cnoremap    Command-line
  154.  
  155.  
  156. RECURSIVE MAPPING
  157.  
  158. When a mapping triggers itself, it will run forever.  This can be used to
  159. repeat an action an unlimited number of times.
  160.    For example, you have a list of files that contain a version number in the
  161. first line.  You edit these files with "vim *.txt".  You are now editing the
  162. first file.  Define this mapping: >
  163.  
  164.     :map ,, :s/5.1/5.2/<CR>:wnext<CR>,,
  165.  
  166. Now you type ",,".  This triggers the mapping.  It replaces "5.1" with "5.2"
  167. in the first line.  Then it does a ":wnext" to write the file and edit the
  168. next one.  The mapping ends in ",,".  This triggers the same mapping again,
  169. thus doing the substitution, etc.
  170.    This continues until there is an error.  In this case it could be a file
  171. where the substitute command doesn't find a match for "5.1".  You can then
  172. make a change to insert "5.1" and continue by typing ",," again.  Or the
  173. ":wnext" fails, because you are in the last file in the list.
  174.    When a mapping runs into an error halfway, the rest of the mapping is
  175. discarded.  CTRL-C interrupts the mapping (CTRL-Break on MS-Windows).
  176.  
  177.  
  178. DELETE A MAPPING
  179.  
  180. To remove a mapping use the ":unmap" command.  Again, the mode the unmapping
  181. applies to depends on the command used:
  182.  
  183.     :unmap        Normal, Visual and Operator-pending
  184.     :vunmap        Visual
  185.     :nunmap        Normal
  186.     :ounmap        Operator-pending
  187.     :unmap!        Insert and Command-line
  188.     :iunmap        Insert
  189.     :cunmap        Command-line
  190.  
  191. There is a trick to define a mapping that works in Normal and Operator-pending
  192. mode, but not in Visual mode.  First define it for all three modes, then
  193. delete it for Visual mode: >
  194.  
  195.     :map <C-A> /---><CR>
  196.     :vunmap <C-A>
  197.  
  198. Notice that the five characters "<C-A>" stand for the single key CTRL-A.
  199.  
  200. To remove all mappings use the |:mapclear| command.  You can guess the
  201. variations for different modes by now.  Be careful with this command, it can't
  202. be undone.
  203.  
  204.  
  205. SPECIAL CHARACTERS
  206.  
  207. The ":map" command can be followed by another command.  A | character
  208. separates the two commands.  This also means that a | character can't be used
  209. inside a map command.  To include one, use <Bar> (five characters).  Example:
  210. >
  211.     :map <F8> :write <Bar> !checkin %<CR>
  212.  
  213. The same problem applies to the ":unmap" command, with the addition that you
  214. have to watch out for trailing white space.  These two commands are different:
  215. >
  216.     :unmap a | unmap b
  217.     :unmap a| unmap b
  218.  
  219. The first command tries to unmap "a ", with a trailing space.
  220.  
  221. When using a space inside a mapping, use <Space> (seven characters): >
  222.  
  223.     :map <Space> W
  224.  
  225. This makes the spacebar move a blank-separated word forward.
  226.  
  227. It is not possible to put a comment after a mapping, because the " character
  228. is considered to be part of the mapping.
  229.  
  230.  
  231. MAPPINGS AND ABBREVIATIONS
  232.  
  233. Abbreviations are a lot like Insert mode mappings.  The arguments are handled
  234. in the same way.  The main difference is the way they are triggered.  An
  235. abbreviation is triggered by typing a non-word character after the word.  A
  236. mapping is triggered when typing the last character.
  237.    Another difference is that the characters you type for an abbreviation are
  238. inserted in the text while you type them.  When the abbreviation is triggered
  239. these characters are deleted and replaced by what the abbreviation produces.
  240. When typing the characters for a mapping, nothing is inserted until you type
  241. the last character that triggers it.  If the 'showcmd' option is set, the
  242. typed characters are displayed in the last line of the Vim window.
  243.    An exception is when a mapping is ambiguous.  Suppose you have done two
  244. mappings: >
  245.  
  246.     :imap aa foo
  247.     :imap aaa bar
  248.  
  249. Now, when you type "aa", Vim doesn't know if it should apply the first or the
  250. second mapping.  It waits for another character to be typed.  If it is an "a",
  251. the second mapping is applied and results in "bar".  If it is a space, for
  252. example, the first mapping is applied, resulting in "foo", and then the space
  253. is inserted.
  254.  
  255.  
  256. ADDITIONALLY...
  257.  
  258. The <script> keyword can be used to make a mapping local to a script.  See
  259. |:map-<script>|.
  260.  
  261. The <buffer> keyword can be used to make a mapping local to a specific buffer.
  262. See |:map-<buffer>|
  263.  
  264. The <unique> keyword can be used to make defining a new mapping fail when it
  265. already exists.  Otherwise a new mapping simply overwrites the old one.  See
  266. |:map-<unique>|.
  267.  
  268. To make a key do nothing, map it to <Nop> (five characters).  This will make
  269. the <F7> key do nothing at all: >
  270.  
  271.     :map <F7> <Nop>| map! <F7> <Nop>
  272.  
  273. There must be no space after <Nop>.
  274.  
  275. ==============================================================================
  276. *40.2*    Defining command-line commands
  277.  
  278. The Vim editor enables you to define your own commands.  You execute these
  279. commands just like any other Command-line mode command.
  280.    To define a command, use the ":command" command, as follows: >
  281.  
  282.     :command DeleteFirst 1delete
  283.  
  284. Now when you execute the command ":DeleteFirst" Vim excutes ":1delete", which
  285. deletes the first line.
  286.  
  287.     Note:
  288.     User-defined commands must start with a capital letter.  You cannot
  289.     use ":X", ":Next" and ":Print".  The underscore cannot be used!  You
  290.     can use digits, but this is discouraged.
  291.  
  292. To list the user-defined commands, execute the following command: >
  293.  
  294.     :command
  295.  
  296. Just like with the builtin commands, the user defined commands can be
  297. abbreviated.  You need to type just enough to distinguish the command from
  298. another.  Command line completion can be used to get the full name.
  299.  
  300.  
  301. NUMBER OF ARGUMENTS
  302.  
  303. User-defined commands can take a series of arguments.  The number of arguments
  304. must be specified by the -nargs option.  For instance, the example
  305. :DeleteFirst command takes no arguments, so you could have defined it as
  306. follows: >
  307.  
  308.     :command -nargs=0 DeleteFirst 1delete
  309.  
  310. However, because zero arguments is the default, you do not need to add
  311. "-nargs=0".  The other values of -nargs are as follows:
  312.  
  313.     -nargs=0    No arguments
  314.     -nargs=1    One argument
  315.     -nargs=*    Any number of arguments
  316.     -nargs=?    Zero or one argument
  317.     -nargs=+    One or more arguments
  318.  
  319.  
  320. USING THE ARGUMENTS
  321.  
  322. Inside the command definition, the arguments are represented by the
  323. <args> keyword.  For example: >
  324.  
  325.     :command -nargs=+ Say :echo "<args>"
  326.  
  327. Now when you type >
  328.  
  329.     :Say Hello World
  330.  
  331. Vim echoes "Hello World".  However, if you add a double quote, it won't work.
  332. For example: >
  333.  
  334.     :Say he said "hello"
  335.  
  336. To get special characters turned into a string, properly escaped to use as an
  337. expression, use "<q-args>": >
  338.  
  339.     :command -nargs=+ Say :echo <q-args>
  340.  
  341. Now the above ":Say" command will result in this to be executed: >
  342.  
  343.     :echo "he said \"hello\""
  344.  
  345. The <f-args> keyword contains the same information as the <args> keyword,
  346. except in a format suitable for use as function call arguments.  For example:
  347. >
  348.     :command -nargs=* DoIt :call AFunction(<f-args>)
  349.     :DoIt a b c
  350.  
  351. Execute the following command: >
  352.  
  353.     :call AFunction("a", "b", "c")
  354.  
  355.  
  356. LINE RANGE
  357.  
  358. Some commands take a range as their argument.  To tell Vim that you are
  359. defining such a command, you need to specify a -range option.  The values for
  360. this option are as follows:
  361.  
  362.     -range        Range is allowed; default is the current line.
  363.     -range=%    Range is allowed; default is the whole file.
  364.     -range={count}    Range is allowed; the last number in it is used as a
  365.             single number whose default is {count}.
  366.  
  367. When a range is specified, the keywords <line1> and <line2> get the values of
  368. the first and last line in the range.  For example, the following command
  369. defines the SaveIt command, which writes out the specified range to the file
  370. "save_file": >
  371.  
  372.     :command -range=% SaveIt :<line1>,<line2>write! save_file
  373.  
  374.  
  375. OTHER OPTIONS
  376.  
  377. Some of the other options and keywords are as follows:
  378.  
  379.     -count={number}        The command can take a count whose default is
  380.                 {number}.  The resulting count can be used
  381.                 through the <count> keyword.
  382.     -bang            You can use a !. If present, using <bang> will
  383.                 result in a !.
  384.     -register        You can specify a register. (The default is
  385.                 the unnamed register.)
  386.                 The register specification is available as
  387.                 <reg> (a.k.a. <register>).
  388.     -complete={type}    Type of command-line completion used.  See
  389.                 |:command-completion| for the list of possible
  390.                 values.
  391.     -bar            The command can be followed by | and another
  392.                 command, or " and a comment.
  393.     -buffer            The command is only available for the current
  394.                 buffer.
  395.  
  396. Finally, you have the <lt> keyword.  It stands for the character <.  Use this
  397. to escape the special meaning of the <> items mentioned.
  398.  
  399.  
  400. REDEFINING AND DELETING
  401.  
  402. To redefine the same command use the ! argument: >
  403.  
  404.     :command -nargs=+ Say :echo "<args>"
  405.     :command! -nargs=+ Say :echo <q-args>
  406.  
  407. To delete a user command use ":delcommand".  It takes a single argument, which
  408. is the name of the command.  Example: >
  409.  
  410.     :delcommand SaveIt
  411.  
  412. To delete all the user commands: >
  413.  
  414.     :comclear
  415.  
  416. Careful, this can't be undone!
  417.  
  418. More details about all this in the reference manual: |user-commands|.
  419.  
  420. ==============================================================================
  421. *40.3*    Autocommands
  422.  
  423. An autocommand is a command that is executed automatically in response to some
  424. event, such as a file being read or written or a buffer change. Through the
  425. use of autocommands you can train Vim to edit compressed files, for example.
  426. That is used in the |gzip| plugin.
  427.    Autocommands are very powerful.  Use them with care and they will help you
  428. avoid typing many commands.  Use them carelessly and they will cause a lot of
  429. trouble.
  430.  
  431. Suppose you want to replace a date stamp on the end of a file every time it is
  432. written.  First you define a function: >
  433.  
  434.     :function DateInsert()
  435.     :  $delete
  436.     :  read !date
  437.     :endfunction
  438.  
  439. You want this function to be called each time, just before a file is written.
  440. This will make that happen: >
  441.  
  442.     :autocmd FileWritePre *  call DateInsert()
  443.  
  444. "FileWritePre" is the event for which this autocommand is triggered: Just
  445. before (pre) writing a file.  The "*" is a pattern to match with the file
  446. name.  In this case it matches all files.
  447.    With this command enabled, when you do a ":write", Vim checks for any
  448. matching FileWritePre autocommands and executes them, and then it
  449. performs the ":write".
  450.    The general form of the :autocmd command is as follows: >
  451.  
  452.     :autocmd [group] {events} {file_pattern} [nested] {command}
  453.  
  454. The [group] name is optional.  It is used in managing and calling the commands
  455. (more on this later).  The {events} parameter is a list of events (comma
  456. separated) that trigger the command.
  457.    {file_pattern} is a filename, usually with wildcards.  For example, using
  458. "*.txt" makes the autocommand be used for all files whose name end in ".txt".
  459. The optional [nested] flag allows for nesting of autocommands (see below), and
  460. finally, {command} is the command to be executed.
  461.  
  462.  
  463. EVENTS
  464.  
  465. One of the most useful events is BufReadPost.  It is triggered after a new
  466. file is being edited.  It is commonly used to set option values.  For example,
  467. you know that "*.gsm" files are GNU assembly language.  To get the syntax file
  468. right, define this autocommand: >
  469.  
  470.     :autocmd BufReadPost *.gsm  set filetype=asm
  471.  
  472. If Vim is able to detect the type of file, it will set the 'filetype' option
  473. for you.  This triggers the Filetype event.  Use this to do something when a
  474. certain type of file is edited.  For example, to load a list of abbreviations
  475. for text files: >
  476.  
  477.     :autocmd Filetype text  source ~/.vim/abbrevs.vim
  478.  
  479. When starting to edit a new file, you could make Vim insert a skeleton: >
  480.  
  481.     :autocmd BufNewFile *.[ch]  0read ~/skeletons/skel.c
  482.  
  483. See |autocmd-events| for a complete list of events.
  484.  
  485.  
  486. PATTERNS
  487.  
  488. The {file_pattern} argument can actually be a comma-separated list of file
  489. patterns.  For example: "*.c,*.h" matches files ending in ".c" and ".h".
  490.    The usual file wildcards can be used.  Here is a summary of the most often
  491. used ones:
  492.  
  493.     *        Match any character any number of times
  494.     ?        Match any character once
  495.     [abc]        Match the character a, b or c
  496.     .        Matches a dot
  497.     a{b,c}        Matches "ab" and "ac"
  498.  
  499. When the pattern includes a slash (/) Vim will compare directory names.
  500. Without the slash only the last part of a file name is used.  For example,
  501. "*.txt" matches "/home/biep/readme.txt".  The pattern "/home/biep/*" would
  502. also match it.  But "home/foo/*.txt" wouldn't.
  503.    When including a slash, Vim matches the pattern against both the full path
  504. of the file ("/home/biep/readme.txt") and the relative path (e.g.,
  505. "biep/readme.txt").
  506.  
  507.     Note:
  508.     When working on a system that uses a backslash as file separater, such
  509.     as MS-Windows, you still use forward slashes in autocommands.  This
  510.     makes it easier to write the pattern, since a backslash has a special
  511.     meaning.  It also makes the autocommands portable.
  512.  
  513.  
  514. DELETING
  515.  
  516. To delete an autocommand, use the same command as what it was defined with,
  517. but leave out the {command} at the end and use a !.  Example: >
  518.  
  519.     :autocmd! FileWritePre *
  520.  
  521. This will delete all autocommands for the "FileWritePre" event that use the
  522. "*" pattern.
  523.  
  524.  
  525. LISTING
  526.  
  527. To list all the currently defined autocommands, use this: >
  528.  
  529.     :autocmd
  530.  
  531. The list can be very long, especially when filetype detection is used.  To
  532. list only part of the commands, specify the group, event and/or pattern.  For
  533. example, to list all BufNewFile autocommands: >
  534.  
  535.     :autocmd BufNewFile
  536.  
  537. To list all autocommands for the pattern "*.c": >
  538.  
  539.     :autocmd * *.c
  540.  
  541. Using "*" for the event will list all the events.  To list all autocommands
  542. for the cprograms group: >
  543.  
  544.     :autocmd cprograms
  545.  
  546.  
  547. GROUPS
  548.  
  549. The {group} item, used when defining an autocommand, groups related autocommands
  550. together.  This can be used to delete all the autocommands in a certain group,
  551. for example.
  552.    When defining several autocommands for a certain group, use the ":augroup"
  553. command.  For example, let's define autocommands for C programs: >
  554.  
  555.     :augroup cprograms
  556.     :  autocmd BufReadPost *.c,*.h :set sw=4 sts=4
  557.     :  autocmd BufReadPost *.cpp   :set sw=3 sts=3
  558.     :augroup END
  559.  
  560. This will do the same as: >
  561.  
  562.     :autocmd cprograms BufReadPost *.c,*.h :set sw=4 sts=4
  563.     :autocmd cprograms BufReadPost *.cpp   :set sw=3 sts=3
  564.  
  565. To delete all autocommands in the "cprograms" group: >
  566.  
  567.     :autocmd! cprograms
  568.  
  569.  
  570. NESTING
  571.  
  572. Generally, commands executed as the result of an autocommand event will not
  573. trigger any new events.  If you read a file in response to a FileChangedShell
  574. event, it will not trigger the autocommands that would set the syntax, for
  575. example.  To make the events triggered, add the "nested" argument: >
  576.  
  577.     :autocmd FileChangedShell * nested  edit
  578.  
  579.  
  580. EXECUTING AUTOCOMMANDS
  581.  
  582. It is possible to trigger an autocommand by pretending an event has occurred.
  583. This is useful to have one autocommand trigger another one.  Example: >
  584.  
  585.     :autocmd BufReadPost *.new  execute "doautocmd BufReadPost " . expand("<afile>:r")
  586.  
  587. This defines an autocommand that is triggered when a new file has been edited.
  588. The file name must end in ".new".  The ":execute" command uses expression
  589. evaluation to form a new command and execute it.  When editing the file
  590. "tryout.c.new" the executed command will be: >
  591.  
  592.     :doautocmd BufReadPost tryout.c
  593.  
  594. The expand() function takes the "<afile>" argument, which stands for the file
  595. name the autocommand was executed for, and takes the root of the file name
  596. with ":r".
  597.  
  598. ":doautocmd" executes on the current buffer.  The ":doautoall" command works
  599. like "doautocmd" except it executes on all the buffers.
  600.  
  601.  
  602. USING NORMAL MODE COMMANDS
  603.  
  604. The commands executed by an autocommand are Command-line command.  If you want
  605. to use a Normal mode command, the ":normal" command can be used.  Example: >
  606.  
  607.     :autocmd BufReadPost *.log normal G
  608.  
  609. This will make the cursor jump to the last line of *.log files when you start
  610. to edit it.
  611.    Using the ":normal" command is a bit tricky.  First of all, make sure its
  612. argument is a complete command, including all the arguments.  When you use "i"
  613. to go to Insert mode, there must also be a <Esc> to leave Insert mode again.
  614. If you use a "/" to start a search pattern, there must be a <CR> to execute
  615. it.
  616.    The ":normal" command uses all the text after it as commands.  Thus there
  617. can be no | and another command following.  To work around this, put the
  618. ":normal" command inside an ":execute" command.  This also makes it possible
  619. to pass unprintable characters in a convenient way.  Example: >
  620.  
  621.     :autocmd BufReadPost *.chg execute "normal ONew entry:\<Esc>" |
  622.         \ 1read !date
  623.  
  624. This also shows the use of a backslash to break a long command into more
  625. lines.  This can be used in Vim scripts (not at the command line).
  626.  
  627. When you want the autocommand do something complicated, which involves jumping
  628. around in the file and then returning to the original position, you may want
  629. to restore the view on the file.  See |restore-position| for an example.
  630.  
  631.  
  632. IGNORING EVENTS
  633.  
  634. At times, you will not want to trigger an autocommand.  The 'eventignore'
  635. option contains a list of events that will be totally ignored.  For example,
  636. the following causes events for entering and leaving a window to be ignored: >
  637.  
  638.     :set eventignore=WinEnter,WinLeave
  639.  
  640. To ignore all events, use the following command: >
  641.  
  642.     :set eventignore=all
  643.  
  644. To set it back to the normal behavior, make 'eventignore' empty: >
  645.  
  646.     :set eventignore=
  647.  
  648. ==============================================================================
  649.  
  650. Next chapter: |usr_41.txt|  Write a Vim script
  651.  
  652. Copyright: see |manual-copyright|  vim:tw=78:ts=8:ft=help:norl:
  653.